<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org" >
<head>
    <meta charset="UTF-8">
    <title>菜单管理-右</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta http-equiv="Access-Control-Allow-Origin" content="*">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <link rel="icon" th:href="@{/resources/favicon.ico}">
    <link rel="stylesheet" th:href="@{/resources/layui/css/layui.css}" media="all"/>
    <link rel="stylesheet" th:href="@{/resources/css/public.css}" media="all"/>
</head>
<body class="childrenBody">
<!-- 查询条件开始 -->
<fieldset class="layui-elem-field layui-field-title" style="margin-top: 5px;">
    <legend>查询条件</legend>
</fieldset>
<blockquote class="layui-elem-quote">
    <form method="post" id="searchFrm" lay-filter="searchFrm" class="layui-form-pane">
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">菜单名称</label>
                <div class="layui-input-inline">
                    <input type="text" name="title"  autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <button type="button" id="doSearch" class="layui-btn" lay-submit="" lay-filter="doSearch"><span class="layui-icon layui-icon-search"></span>查询</button>
                <button type="button" id="doReset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh-1"></span>重置</button>
            </div>
        </div>
    </form>
</blockquote>
<!-- 查询条件结束-->

<!-- 数据表格开始 -->
<div>
    <table class="layui-hide" id="menuTable" lay-filter="menuTable"></table>
    <div id="menuToolBar" style="display: none;">
        <button type="button"  lay-event="add" class="layui-btn layui-btn-sm"><span class="layui-icon layui-icon-add-1"></span>添加菜单</button>
<!--        <button type="button"  lay-event="batchDelete" class="layui-btn layui-btn-sm layui-btn-danger"><span class="layui-icon layui-icon-delete"></span>批量删除</button>-->
    </div>
    <div id="siteRowBar" style="display: none;">
        <button type="button" lay-event="update" class="layui-btn layui-btn-sm"><span class="layui-icon layui-icon-edit"></span>更新</button>
        <button type="button" lay-event="delete" class="layui-btn layui-btn-sm layui-btn-danger"><span class="layui-icon layui-icon-delete"></span>删除</button>
    </div>
</div>
<!-- 数据表格结束 -->

<!-- 添加和修改的弹出层开始 -->
<div style="display: none;padding: 5px" id="addOrUpdateDiv">
    <form action="" method="post" class="layui-form layui-form-pane" id="dataFrm" lay-filter="dataFrm">
        <div class="layui-form-item">
            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">父ID</label>
                    <div class="layui-input-block">
                        <input type="hidden" name="id">
                        <input type="text" name="pid"   autocomplete="off" placeholder="请输入父ID" class="layui-input">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">菜单类型</label>
                    <div class="layui-input-block">
                        <input type="text" name="type"   autocomplete="off" placeholder="请输入菜单类型" class="layui-input">
                    </div>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">菜单名称</label>
                    <div class="layui-input-block">
                        <input type="text" name="title"   autocomplete="off" placeholder="请输入菜单名称" class="layui-input">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">菜单图标</label>
                    <div class="layui-input-block">
                        <input type="text" name="icon"   autocomplete="off" placeholder="请输入菜单图标" class="layui-input">
                    </div>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">菜单地址</label>
                    <div class="layui-input-block">
                        <input type="text" name="href"   autocomplete="off" placeholder="请输入菜单地址" class="layui-input">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">是否展开</label>
                    <div class="layui-input-block">
                        <input type="radio" name="open" value="1" title="展开" >
                        <input type="radio" name="open" value="0" title="不展开" checked="">
                    </div>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">是否可用</label>
                    <div class="layui-input-block">
                        <input type="radio" name="available" value="1" title="可用" checked="">
                        <input type="radio" name="available" value="0" title="不可用" >
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">排序号</label>
                    <div class="layui-input-block">
                        <input type="text" name="num" id="num" lay-verify="required|number"  autocomplete="off" placeholder="请输入排序码[>0]" class="layui-input">
                    </div>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-input-block" style="text-align: center;margin-left: 0px">
                    <button type="button" class="layui-btn" lay-submit="" lay-filter="doSubmit" id="doSubmit" ><span class="layui-icon layui-icon-add-1"></span>提交</button>
                    <button type="reset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh-1"></span>重置</button>
                </div>
            </div>
        </div>
    </form>
</div>
<!-- 添加和修改的弹出层结束 -->

<script type="text/javascript" th:src="@{/resources/layui/layui.js}"></script>
<script type="text/javascript" th:src="@{/resources/layui_ext/dtree/dtree.js}"></script>
<script type="text/javascript">
    var tableIns;
    layui.use(['jquery','form','table','layer','layedit','dtree'],function(){
        var $=layui.jquery;
        var form=layui.form;
        var table=layui.table;
        var layer=layui.layer;
        var layedit=layui.layedit;
        var dtree=layui.dtree;

        //初始化富文本
        var editIndex = layedit.build('content');
        //加载数据
            tableIns=table.render({
            elem: '#menuTable'
            ,url:'/menu/loadAllMenuJson'
            ,toolbar: '#menuToolBar' //开启头部工具栏，并为其绑定左侧模板
            ,title: '菜单数据'
            ,height:'full-180'
            ,limit:'20'
            ,limits:[20,40,60,80]
            ,page: true
            ,cols: [ [
                {type: 'checkbox', fixed: 'left'}
                ,{field:'id', title:'ID',align:'center',width:'100'}
                ,{field:'pid', title:'父ID',align:'center',width:'100'}
                ,{field:'type', title:'菜单类型',align:'center',width:'100'}
                ,{field:'title', title:'菜单名称',align:'center',width:'150'}
                ,{field:'icon', title:'菜单图标',align:'center',width:'100',templet:function(d){
                    return '<font class=layui-icon>'+d.icon+'</font>';}}
                ,{field:'href', title:'菜单地址',align:'center',width:'200'}
                ,{field:'open', title:'是否展开',align:'center',width:'135',templet:function(d){
                    return d.open==1?'<font color=blue>展开</font>':'<font color=red>不展开</font>';}}
                ,{field:'available', title:'是否可用',align:'center',width:'135',templet:function(d){
                    return d.available==1?'<font color=blue>可用</font>':'<font color=red>不可用</font>';}}
                ,{field:'num', title:'排序号',align:'center',width:'135'}
                ,{fixed: 'right', title:'操作', toolbar: '#siteRowBar',align:'center',width:'250'}
            ] ]
        });

        //模糊查询
        $("#doSearch").click(function () {
            var params=$("#searchFrm").serialize();
            tableIns.reload({
                url:'/menu/loadAllMenuJson?'+params,
                page:{
                    curr:1
                }
            });
            return false;
        })
        $("#doReset").click(function () {
            $("#searchFrm")[0].reset()
            $("#doSearch").click()
        })

        //监听工具条的事件
        table.on("toolbar(menuTable)",function(obj){
            switch(obj.event){
                case 'batchDelete':
                    batchDelete();
                    break;
                case 'add':
                    openAddLayer();
                    break;
            }
        });

        //监听行工具条的事件
        table.on("tool(menuTable)",function(obj){
            var data = obj.data; //获得当前行数据
            switch(obj.event){
                case 'update':
                    openupdateMenuLayer(data);
                    break;
                case 'delete':
                    deleteMenu(data);
                    break;
            }
        });

        var mainIndex;
        var url;
        //打开添加的弹出层
        function openAddLayer(){
            mainIndex=layer.open({
                type:1,
                content:$("#addOrUpdateDiv"),
                area:['660px','390px'],
                title:'添加菜单',
                success:function(){
                    $("#dataFrm")[0].reset();
                    url="/menu/addMenu";
                    $.get("/menu/loadMenuMaxNum",function(res){
                        $("#num").val(res.value);
                    });
                }
            });
        }

        //打开修改的弹出层
        function openupdateMenuLayer(data){
            mainIndex=layer.open({
                type:1,
                content:$("#addOrUpdateDiv"),
                area:['660px','390px'],
                title:'修改菜单',
                success:function(){
                    $("#dataFrm")[0].reset();
                    //装载新的数据
                    form.val("dataFrm",data);
                    layedit.setContent(editIndex,data.content);
                    url="/menu/updateMenu";
                }
            });
        }
        $("#doSubmit").click(function(){
            layedit.sync(editIndex);
            var data=$("#dataFrm").serialize();
            $.post(url,data,function(res){
                if(res.code==200){
                    tableIns.reload();
                }
                layer.msg(res.msg);
                layer.close(mainIndex);
            })
        })
        //删除
        function deleteMenu(data){
            layer.confirm('你确定要删除【'+data.title+'】这个菜单吗?', {icon: 3, title:'提示'}, function(index){
                $.post("/menu/deleteMenu",{id:data.id},function(res){
                    if(res.code==200){
                        tableIns.reload();
                    }
                    layer.msg(res.msg);
                })
                layer.close(index);
            });
        }
    });
    //给其它页面刷新当前页面数据表格的方法
    function reloadTable(id){
        tableIns.reload({
            where:{
                id:id
            },
            page:{
                curr:1
            }
        });
    }

</script>
</body>
</html>
